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SYSTEMS AND METHODS FOR ACCELERATED LOADING OF 
OPERATING SYSTEMS AND APPLICATION PROGRAMS 

CROSS-RFFFRFNCF TO RFI ATFD APPLICATION 

5 This application is based on a United States provisional application Serial No. 

60/180,1 14, filed on February 3, 2000, which is fully incorporated herein by reference. 

BACKGROUND 

L Technical Field 

1 0 The present invention relates generally to systems and methods for providing 

accelerated loading of operating system and application programs upon system boot or 
application launch and, more particularly, to data storage controllers employing lossless 
and/or lossy data compression and decompression to provide accelerated loading of 
operating systems and application programs. 

15 2. Description of the Related Art 

Modern computers utilize a hierarchy of memory devices. To achieve maximum 
performance levels, modern processors utilize onboard memory and on board cache to 
obtain high bandwidth access to both program and data. Limitations in process 
technologies currently prohibit placing a sufficient quantity of onboard memory for most 

2 0 applications. Thus, in order to offer sufficient memory for the operating system(s), 
application programs, and user data, computers often use various forms of popular off- 
processor high speed memory including static random access memory (SRAM), 
synchronous dynamic random access memory (SDRAM), synchronous burst static ram 
(SBSRAM). Due to the prohibitive cost of the high-speed random access memory, 

2 5 coupled with their power volatility, a third lower level of the hierarchy exists for non- 
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volatile mass storage devices. 

Furthermore, mass storage devices offer increased capacity and fairly economical 
data storage. Mass storage devices (such as a "hard disk") typically store the operating 
system of a computer system, as well as applications and data and rapid access to such 
5 data is critical to system performance. The data storage and retrieval bandwidth of mass 
storage devices, however, is typically much less as compared with the bandwidth of other 
elements of a computing system. Indeed, over the last decade, although computer 
processor performance has improved by at least a factor of 50, magnetic disk storage 
performance has only improved by a factor of 5. Consequently, memory storage devices 

1 0 severely limit the performance of consumer, entertainment, office, workstation, servers, 
and mainframe computers for all disk and memory intensive operations. 

The ubiquitous Internet combined with new multimedia applications has put 
tremendous emphasis on storage volumetric density, storage mass density, storewidth, 
and power consumption. Specifically, storage density is limited by the number of bits 

1 5 that are encoded in a mass storage device per unit volume. Similarly mass density is 

defined as storage bits per unit mass. Storewidth is the data rate at which the data may be 
accessed. There are various ways of categorizing storewidth in terms, several of the more 
prevalent metrics include sustained continuous storewidth, burst storewidth, and random 
access storewidth, all typically measured in megabytes/sec. Power consumption is 

2 0 canonically defined in terms of power consumption per bit and may be specified under a 
number of operating modes including active (while data is being accessed and 
transmitted) and standby mode. Hence one fairly obvious limitation within the current art 
is the need for even more volume, mass, and power efficient data storage. 
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Magnetic disk mass storage devices currently employed in a variety of home, 
business, and scientific computing applications suffer from significant seek-time access 
delays along with profound read/write data rate limitations. Currently the fastest available 
disk drives support only a sustained output data rate in the tens of megabytes per second 
5 data rate (MB/sec). This is in stark contrast to the modern Personal Computer's 

Peripheral Component Interconnect (PCI) Bus's low end 32 bit / 33Mhz input/output 
capability of 264 MB/sec and the PC's internal local bus capability of 800 MB/sec. 

Another problem within the current art is that emergent high performance disk 
interface standards such as the Small Computer Systems Interface (SCSI-3), Fibre 

1 0 Channel, AT Attachment UltraDMA/66/100, Serial Storage Architecture, and Universal 
Serial Bus offer only higher data transfer rates through intermediate data buffering in 
random access memory. These interconnect strategies do not address the fundamental 
problem that all modern magnetic disk storage devices for the personal computer 
marketplace are still limited by the same typical physical media restrictions. In practice, 

1 5 faster disk access data rates are only achieved by the high cost solution of simultaneously 
accessing multiple disk drives with a technique known within the art as data striping and 
redundant array of independent disks (RAID). 

RAID systems often afford the user the benefit of increased data bandwidth for 
data storage and retrieval. By simultaneously accessing two or more disk drives, data 

2 0 bandwidth may be increased at a maximum rate that is linear and directly proportional to 
the number of disks employed. Thus another problem with modern data storage systems 
utilizing RAID systems is that a linear increase in data bandwidth requires a proportional 
number of added disk storage devices. 
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Another problem with most modern mass storage devices is their inherent 
unreliability. Many modern mass storage devices utilize rotating assemblies and other 
types of electromechanical components that possess failure rates one or more orders of 
magnitude higher than equivalent solid-state devices. RAID systems employ data 
5 redundancy distributed across multiple disks to enhance data storage and retrieval 

reliability. In the simplest case, data may be explicitly repeated on multiple places on a 
single disk drive, on multiple places on two or more independent disk drives. More 
complex techniques are also employed that support various trade-offs between data 
bandwidth and data reliability. 

1 0 Standard types of RAID systems currently available include RAID Levels 0, 1, 

and 5. The configuration selected depends on the goals to be achieved. Specifically data 
reliability, data validation, data storage /retrieval bandwidth, and cost all play a role in 
defining the appropriate RAID data storage solution. RAID level 0 entails pure data 
striping across multiple disk drives. This increases data bandwidth at best linearly with 

1 5 the number of disk drives utilized. Data reliability and validation capability are 

decreased. A failure of a single drive results in a complete loss of all data. Thus another 
problem with RAID systems is that low cost improved bandwidth requires a significant 
decrease in reliability. 

RAID Level 1 utilizes disk mirroring where data is duplicated on an independent 

2 0 disk subsystem. Validation of data amongst the two independent drives is possible if the 
data is simultaneously accessed on both disks and subsequently compared. This tends to 
decrease data bandwidth from even that of a single comparable disk drive. In systems 
that offer hot swap capability, the failed drive is removed and a replacement drive is 
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inserted. The data on the failed drive is then copied in the background while the entire 
system continues to operate in a performance degraded but fully operational mode. Once 
the data rebuild is complete, normal operation resumes. Hence, another problem with 
RAID systems is the high cost of increased reliability and associated decrease in 
5 performance. 

RAID Level 5 employs disk data striping and parity error detection to increase 
both data bandwidth and reliability simultaneously. A minimum of three disk drives is 
required for this technique. In the event of a single disk drive failure, that drive may be 
rebuilt from parity and other data encoded on disk remaining disk drives. In systems that 

1 0 offer hot swap capability, the failed drive is removed and a replacement drive is inserted. 
The data on the failed drive is then rebuilt in the background while the entire system 
continues to operate in a performance degraded but fully operational mode. Once the 
data rebuild is complete, normal operation resumes. 

Thus another problem with redundant modern mass storage devices is the 

1 5 degradation of data bandwidth when a storage device fails. Additional problems with 
bandwidth limitations and reliability similarly occur within the art by all other forms of 
sequential, pseudo-random, and random access mass storage devices. These and other 
limitations within the current art are addressed by the present invention. 

SUMMARY OF THE INVENTION 

2 0 The present invention is directed to systems and methods for providing 

accelerated loading of operating system and application programs upon system boot or 
application launch and, more particularly, to data storage controllers employing lossless 
and/or lossy data compression and decompression to provide accelerated loading of 
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operating systems and application programs. 

In one aspect of the present invention, a method for providing accelerated loading 

of an operating system comprises the steps of: maintaining a list of boot data used for 

booting a computer system; preloading the boot data upon initialization of the computer 
5 system; and servicing requests for boot data from the computer system using the 

preloaded boot data. The boot data may comprise program code associated with an 

operating system of the computer system, an application program, and a combination 

thereof. In a preferred embodiment, the boot data is retrieved from a boot device and 

stored in a cache memory device. 
10 In another aspect, the method for accelerated loading of an operating system 

comprises updating the list of boot data during the boot process. The step of updating 

comprises adding to the list any boot data requested by the computer system not 

previously stored in the list and/or removing from the list any boot data previously stored 

in the list and not requested by the computer system. 
15 In yet another aspect, the boot data is stored in a compressed format on the boot 

device and the preloaded boot data is decompressed prior to transmitting the preloaded 

boot data to the requesting system. 

In another aspect, a method for providing accelerated launching of an application 

program comprises the steps of: maintaining a list of application data associated with an 
2 0 application program; preloading the application data upon launching the application 

program; and servicing requests for application data from a computer system using the 

preloaded application data. 

In yet another aspect, a boot device controller for providing accelerated loading of 
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an operating system of a host system comprises: a digital signal processor (DSP); a 
programmable logic device, wherein the programmable logic device is programmed by 
the digital signal processor to (i) instantiate a first interface for operatively interfacing the 
boot device controller to a boot device and to (ii) instantiate a second interface for 
operatively interfacing the boot device controller to the host system; and a non- volatile 
memory device, for storing logic code associated with the DSP, the first interface and the 
second interface, wherein the logic code comprises instructions executable by the DSP for 
maintaining a list of boot data used for booting the host system, preloading the boot data 
upon initialization of the host system, and servicing requests for boot data from the host 
system using the preloaded boot data. The boot device controller further includes a 
cache memory device for storing the preloaded boot data. 

The present invention is realized due to recent improvements in processing speed, 
inclusive of dedicated analog and digital hardware circuits, central processing units, (and 
any hybrid combinations thereof), that, coupled with advanced data compression and 
decompression algorithms are enabling of ultra high bandwidth data compression and 
decompression methods that enable improved data storage and retrieval bandwidth 

These and other aspects, features and advantages, of the present invention will 
become apparent from the following detailed description of preferred embodiments that 
is to be read in connection with the accompanying drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram of a data storage controller according to one embodiment 
of the present invention; 
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Fig. 2 is a block diagram of a data storage controller according to another 
embodiment of the present invention; 

Fig. 3 is a block diagram of a data storage controller according to another 
embodiment of the present invention; 
5 Fig. 4 is a block diagram of a data storage controller according to another 

embodiment of the present invention; 

Fig. 5 is a block diagram of a data storage controller according to another 
embodiment of the present invention; 

Figs. 6a and 6b comprise a flow diagram of a method for initializing a data 
1 0 storage controller according to one aspect of the present invention; 

Figs. 7a and 7b comprise a flow diagram of a method for providing accelerated 
loading of an operating system and/or application programs upon system boot, according 
to one aspect of the present invention; 

Figs. 8a and 8b comprise a flow diagram of a method for providing accelerated 
1 5 loading of application programs according to one aspect of the present invention; 

Fig. 9 is a diagram of an exemplary data compression system that may be 
employed in a data storage controller according to the present invention; and 

Fig. 10 is a diagram of an exemplary data decompression system that may be 
employed in a data storage controller according to the present invention. 
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PET ATT ED DESCRIPTION OF PREFERRED EMBODIMENTS 

In the following description, it is to be understood that system elements having 
equivalent or similar functionality are designated with the same reference numerals in the 
Figures. It is to be further understood that the present invention may be implemented in 
5 various forms of hardware, software, firmware, or a combination thereof. Preferably, the 
present invention is implemented on a computer platform including hardware such as one 
or more central processing units (CPU) or digital signal processors (DSP), a random 
access memory (RAM), and input/output (I/O) interface(s). The computer platform may 
also include an operating system, microinstruction code, and dedicated processing 
1 0 hardware utilizing combinatorial logic or finite state machines. The various processes 
and functions described herein may be either part of the hardware, microinstruction code 
or application programs that are executed via the operating system, or any combination 
thereof. 

It is to be further understood that, because some of the constituent system 
1 5 components described herein are preferably implemented as software modules, the actual 
system connections shown in the Figures may differ depending upon the manner in that 
the systems are programmed. It is to be appreciated that special purpose microprocessors, 
dedicated hardware, or and combination thereof may be employed to implement the 
present invention. Given the teachings herein, one of ordinary skill in the related art will 
2 0 be able to contemplate these and similar implementations or configurations of the present 
invention. 

L System Arrtiitertiirfis 

The present invention is directed to data storage controllers that provide increased 
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data storage/retrieval rates that are not otherwise achievable using conventional disk 
controller systems and protocols to store/retrieve data to/from mass storage devices. The 
concept of "accelerated" data storage and retrieval was introduced in copending U.S. 
Patent Application Serial No. 09/266,394, filed March 11, 1999, entitled "System and 
5 Methods For Accelerated Data Storage and Retrieval" and copending U.S. Patent 

Application Serial No. 09/481,243, filed January 11, 2000, entitled "System and Methods 
For Accelerated Data Storage and Retrieval," both of which are commonly assigned and 
incorporated herein by reference. In general, as described in the above-incorporated 
applications, "accelerated" data storage comprises receiving a digital data stream at a data 

1 0 transmission rate which is greater that the data storage rate of a target storage device, 
compressing the input stream at a compression rate that increases the effective data 
storage rate of the target storage device and storing the compressed data in the target 
storage device. For instance, assume that a mass storage device (such as a hard disk) has 
a data storage rate of 20 megabytes per second. If a storage controller for the mass 

1 5 storage device is capable of compressing an input data stream with an average 

compression rate of 3 : 1 , then data can be stored in the mass storage device at a rate of 60 
megabytes per second, thereby effectively increasing the storage bandwidth 
("storewidth") of the mass storage device by a factor of three. Similarly, accelerated data 
retrieval comprises retrieving a compressed digital data stream from a target storage 

2 0 device at the rate equal to, e.g., the data access rate of the target storage device and then 
decompressing the compressed data at a rate that increases the effective data access rate 
of the target storage device. Advantageously, accelerated data storage/retrieval mitigates 
the traditional bottleneck associated with, e.g., local and network disk accesses. 
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Referring now to Fig. 1, a high-level block diagram illustrates a data storage 
controller 10 according to one embodiment of the present invention. The data storage 
controller 10 comprises a data compression engine 12 for compressing/decompressing 
data (preferably in real-time or psuedo real-time) stored/retrieved from a hard disk 1 l(or 
5 any other type of mass storage device) to provide accelerated data storage/retrieval. The 
DCE 12 preferably employs the data compression/decompression techniques disclosed in 
U.S. Serial No. 09/210,491 entitled "Content Independent Data Compression Method and 
System/' filed on December 1 1, 1998, which is commonly assigned and which is fully 
incorporated herein by reference. It is to be appreciated that the compression and 

1 0 decompression systems and methods disclosed in U.S. Serial No. 09/210,491 are suitable 
for compressing and decompressing data at rates, which provide accelerated data storage 
and retrieval. A detailed discussion of a preferred "content independent" data 
compression process will be provided below. 

The data storage controller 10 further comprises a cache 13, a disk interface (or 

1 5 disk controller) 1 4 and a bus interface 1 5 . The storage controller 1 0 is operatively 

connected to the hard disk 12 via the disk controller 14 and operatively connected to an 
expansion bus (or main bus) 16 of a computer system via the bus interface 15. The disk 
interface 14 may employ a known disk interface standard such as UltraDMA, SCSI, 
Serial Storage Architecture, FibreChannel or any other interface that provides suitable 

20 disk access data rates. In addition, the storage controller 10 preferably utilizes the 

American National Standard for Information Systems (ANSI) AT Attachment Interface 
(ATA/ATAPI-4) to connect the data storage controller 10 to the hard disk 12. As is 
known in the art, this standard defines the connectors and cables for the physical 
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interconnects between the data storage controller and the storage devices, along with the 
electrical and logical characteristics of the interconnecting signals. 

Further, the bus interface 15 may employ a known standard such as the PCI 
(Peripheral Component Interconnect) bus interface for interfacing with a computer 
5 system. The use of industry standard interfaces and protocols is preferable, as it allows 
the storage controller 10 to be backwards compatible and seamlessly integrated with 
current systems. However in new designs the present invention may be utilize any 
suitable computer interface or combination thereof. 

It is to be understood that although Fig. 1 illustrates a hard disk 12, the storage 

1 0 controller 10 may be employed with any form of memory device including all forms of 
sequential, pseudo-random, and random access storage devices. Storage devices as 
known within the current art include all forms of random access memory, magnetic and 
optical tape, magnetic and optical disks, along with various other forms of solid-state 
mass storage devices. The current invention applies to all forms and manners of memory 

1 5 devices including, but not limited to, storage devices utilizing magnetic, optical, and 
chemical techniques, or any combination thereof. In addition, the cache 13 may 
comprise volatile or non-volatile memory, or any combination thereof. Preferably, the 
cache 13 is implemented in SDRAM (static dynamic random access memory). 

The system of Fig. 1 generally operates as follows. When data is read from disk 

20 by the host computer, data flows from the disk 1 1 through the data storage controller 1 0 
to the host computer. Data is stored in one of several proprietary compression formats on 
the disk 1 1 (e.g., "content independent" data compression). Data blocks are pre-specified 
in length, comprised of single or multiple sectors, and are typically handled in fractional 
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or whole equivalents of tracks, e.g. V 2 track, whole track, multiple tracks, etc. To read 
disk data, a DMA transfer is setup from the disk interface 14 to the onboard cache 
memory 13. The disk interface 14 comprises integral DMA control to allow transfer of 
data from the disk 1 1 directly to the onboard cache 13 without intervention by the DCE 
5 12. It should be noted that the DCE 12 acts as a system level controller and sets-up 

specific registers within both the disk interface 14 and bus interface 15 to facilitate DMA 
transfers to and from the cache memory 13. To initiate a transfer from the disk 1 1 to the 
cache 13, the DMA transfer is setup via specifying the appropriate command (read disk), 
the source address (disk logical block number), amount of data to be transferred (number 

10 of disk logical blocks), and destination address within the onboard cache memory 1 3 . 
Then, a disk data interrupt signal ("DISKINT#") is cleared (if previously set and not 
cleared) and the command is initiated by writing to the appropriate address space. Once 
data has been read from disk 1 1 and placed into onboard cache memory 13, the 
DISKINT# interrupt is asserted notifying the DCE 12 that requested data is now available 

15 in the cache memory 13. Data is then read by the DMA controller within the DCE 12 and 
placed into local memory for subsequent decompression. The decompressed data is then 
DMA transferred from the local memory of the DCE 12 back to the cache memory 13. 
Finally, data is DMA transferred via the bus interface controller 15 from the cache 
memory 13 to the bus 16. It is to be understood that in the read mode, the data storage 

2 0 controller acts as a bus master. A bus DMA transfer is then setup via specifying the 
appropriate command (write to host computer), the source address within the cache 
memory 13, the quantity of data words to be transferred (transfers are preferably in 4 byte 
increments), and the destination address on the host computer. When a bus 16 read or 
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write transaction has completed, the appropriate interrupt signals (respectively referred to 
as PCIRDINT# and PCIWRINT# ) are asserted to the DCE 12. Either of these interrupts 
are cleared by a corresponding interrupt service routines through a read or write to the 
appropriate address of the DCE 12. 
5 Similarly, when data is written to the disk 1 1 from the host computer, data flows 

from the host computer through the data storage controller 10 and onto disk 1 1 . Data is 
normally received from the host computer in uncompressed (raw) format and is 
compressed by the DCE 12 and stored on the disk 1 1 . Data blocks from the host are pre- 
specified in length and are typically handled in blocks that are a fixed multiplier higher 

1 0 than fractional or whole equivalents of tracks, e.g. V* track, whole track, multiple tracks, 
etc. This multiplier is preferably derived from the expected average compression ratio 
that is selected when the disk is formatted with the virtual file management system. To 
read host computer data, a bus DMA transfer is setup from the host bus 16 to the onboard 
cache memory 13. The bus interface controller 15 comprises integral DMA control that 

1 5 allows large block transfers from the host computer directly to the onboard cache 1 3 
without intervention by the DCE 12. The bus interface controller 15 acts as a host 
computer Bus Master when executing such transfer. Once data has been read from the 
host and placed into onboard cache memory 13, the data is read by the onboard DMA 
controller (residing on the DCE 12) and placed into local memory for subsequent 

2 0 compression. The compressed data is then DMA transferred from the local memory of 
the DCE 12 back to the cache memory 13. Finally, data is DMA transferred via the disk 
controller 14 from the cache 13 to the disk 1 1 . 

As discussed in greater detail below, upon host computer power-up or external 
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user reset, the data storage controller 10 initializes the onboard interfaces 14, 5 prior to 
release of the external host bus 16 from reset. The processor of the host computer then 
requests initial data from the disk 1 1 to facilitate the computer's boot-up sequence. The 
host computer requests disk data over the Bus 16 via a command packet issued from the 
5 host computer. Command packets are preferably eight words long (in a preferred 
embodiment, each word comprises 32 bits). Commands are written from the host 
computer to the data storage controller 10 with the host computer as the Bus Master and 
the data storage controller 10 as the slave. The data storage controller 10 includes at least 
one Base Address Register (BAR) for decoding the address of a command queue of the 

10 data storage controller 10. The command queue resides within the cache 13 or within 
onboard memory of the DCE 12. 

When a command is received from the host computer, an interrupt (referred to 
herein as PCICMDINT#) is generated to the DCE processor. The eight-word command is 
read by the DCE 12 and placed into the command queue. Because the commands occupy 

15 a very small amount of memory, the location of the command queue is at the discretion of 
software and the associated system level performance considerations. Commands may be 
moved from the bus interface 16 to the command queue by wither explicit reads and 
writes by the DCE processor or, as explained below, by utilizing programmed DMA from 
an Enhanced DMA Controller (EDMA) residing on the DCE 12. This second technique 

2 0 may better facilitate system throughput by allowing the EDMA to automatically load 

commands while the highly pipelined data compression and decompression processing in 
the DCE is executed fully undisturbed. 

The DCE 12, disk interface 14 and bus interface 15 commonly share the cache 13. 
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As explained in detail below, the storage controller 10 preferably provides maximum 
system bandwidth by allowing simultaneous data transfers between the disk 12 and cache 
13, the DCE 12 and the cache 13, and the expansion bus 16 and the cache 13. This is 
realized by employing an integral DMA (direct memory access) protocol that allows the 
5 DCE 12, disk interface 14 and bus interface 15 to transfer data without interrupting or 
interfering with other ongoing processes. In particular, as explained in detail below, an 
integral bandwidth allocation controller (or arbitrator) is preferably employed to allow the 
DCE 12, disk controller 14, and bus interface 15 to access the onboard cache with a 
bandwidth proportional to the overall bandwidth of the respective interface or processing 

1 0 element. The bandwidth arbitration occurs transparently and does not introduce latency 
in memory accesses. Bandwidth division is preferably performed with a high degree of 
granularity to minimize the size of requisite onboard buffers to synchronize data from the 
disk interface 14 and bus interface 15. 

It is to be appreciated that the implementation of a storage controller according to 

1 5 the present invention significantly accelerates the performance of a computer system and 
significantly increases hard disk data storage capacity. For instance, depending on the 
compression rate, for personal computers running standard Microsoft Windows® based 
business application software, the storage controller provides: (1) an increase of n:l in 
disk storage capacity(for example, assuming a compression ration of 3:1, a 20 gigabyte 

2 0 hard drive effectively becomes a 60 gigabyte hard drive) (2) a significant decrease in the 
computer boot-up time (turn-on and operating system load) and the time for loading 
application software and (3) User data storage and retrieval is increased by a factor of n: 1 . 
Referring now to Fig. 2, a block diagram illustrates a data storage controller 20 
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according to another embodiment of the present invention. More specifically, Fig. 2 
illustrates a PCB (printed circuit board) implementation of the data storage controller 10 
of Fig. 1. The storage controller 20 comprises a DSP (digital signal processor) 21 (or any 
other micro-processor device) that implements the DCE 12 of Fig. 1. The storage 
5 controller 21 further comprises at least one programmable logic device 22 (or volatile 
logic device). The programmable logic device 22 preferably implements the logic 
(program code) for instantiating and driving both the disk interface 14 and the bus 
interface 15 and for providing full DMA capability for the disk and bus interfaces 14, 15. 
Further, as explained in detail below, upon host computer power-up and/or assertion of a 

1 0 system-level "reset" (e.g., PCI Bus reset), the DSP 21 initializes and programs the 
programmable logic device 22 before of the completion of initialization of the host 
computer. This advantageously allows the data storage controller 20 to be ready to accept 
and process commands from the host computer (via the bus 16) and retrieve boot data 
from the disk (assuming the data storage controller 20 is implemented as the boot device 

1 5 and the hard disk stores the boot data (e.g., operating system, etc.)). 

The data storage controller 20 further comprises a plurality of memory devices 
including a RAM (random access memory) device 23 and a ROM (read only memory) 
device 24 (or FLASH memory or other types of non-volatile memory). The RAM device 
23 is utilized as on-board cache and is preferably implemented as SDRAM (preferably, 

20 32 megabytes minimum). The ROM device 24 is utilized for non-volatile storage of logic 
code associated with the DSP 21 and configuration data used by the DSP 21 to program 
the programmable logic device 22. The ROM device 24 preferably comprises a one time 
(erasable) programmable memory (OTP-EPROM) device. 
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The DSP 21 is operatively connected to the memory devices 23, 24 and the 
programmable logic device 22 via a local bus 25. The DSP 21 is also operatively 
connected to the programmable logic device 22 via an independent control bus 26. The 
programmable logic device 22 provides data flow control between the DSP 21 and the 
host computer system attached to the bus 16, as well as data flow control between the 
DSP 21 and the storage device. A plurality of external I/O ports 27 are included for data 
transmission and/or loading of one programmable logic devices. Preferably, the disk 
interface 14 driven by the programmable logic device 22 supports a plurality of hard 
drives. 

The storage controller 20 further comprises computer reset and power up circuitry 
28 (or "boot configuration circuit") for controlling initialization (either cold or warm 
boots) of the host computer system and storage controller 20. A preferred boot 
configuration circuit and preferred computer initialization systems and protocols are 

described in U.S. Patent Application Serial No. (Attorney Docket No. 801 1-10), 

filed concurrently herewith (Express Mail Label No. EL679454245US), which is 
commonly assigned and incorporated herein by reference. Preferably, the boot 
configuration circuit 28 is employed for controlling the initializing and programming the 
programmable logic device 22 during configuration of the host computer system (i.e., 
while the CPU of the host is held in reset). The boot configuration circuit 28 ensures that 
the programmable logic device 22 (and possibly other volatile or partially volatile logic 
devices) is initialized and programmed before the bus 16 (such as a PCI bus) is fully 
reset. 

In particular, when power is first applied to the boot configuration circuit 28, the 
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boot configuration circuit 28 generates a control signal to reset the local system (e.g., 
storage controller 20) devices such as a DSP, memory, and I/O interfaces. Once the local 
system is powered-up and reset, the controlling device (such as the DSP 21) will then 
proceed to automatically determine the system environment and configure the local 
5 system to work within that environment. By way of example, the DSP 21 of the disk 
storage controller 20 would sense that the data storage controller 20 is on a PCI computer 
bus (expansion bus) and has attached to it a hard disk on an IDE interface. The DSP 21 
would then load the appropriate PCI and IDE interfaces into the programmable logic 
device 22 prior to completion of the host system reset. It is to be appreciated that this 

1 0 can be done for all computer busses and boot device interfaces including: PCI, NuBus, 
ISA, Fiber Channel, SCSI, Ethernet, DSL, ADSL, IDE, DMA, Ultra DMA, and SONET. 
Once the programmable logic device 22 is configured for its environment, the boot device 
controller is reset and ready to accept commands over the computer/expansion bus 16. 
Details of the boot process using a boot device comprising a programmable logic device 

1 5 will be provided below. 

It is to be understood that the data storage controller 20 may be utilized as a 
controller for transmitting data (compressed or uncompressed) to and from remote 
locations over the DSP I/O ports 27 or system bus 16, for example. Indeed, the I/O ports 
27 of the DSP 21 may be used for transmitting data (compressed or uncompressed) that is 

2 0 either retrieved from the disk 1 1 or received from the host system via the bus 16, to 

remote locations for processing and/or storage. Indeed, the I/O ports may be operatively 
connected to other data storage controllers or to a network communication channels. 
Likewise, the data storage controller 20 may receive data (compressed or uncompressed) 
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over the I/O ports 27 of the DSP 21 from remote systems that are connected to the I/O 
ports 27 of the DSP, for local processing by the data storage controller 20. For instance, a 
remote system may remotely access the data storage controller (via the I/O ports of the 
DSP or system bus 16) to utilize the data compression, in which case the data storage 
5 controller would transmit the compressed data back to the system that requested 
compression. 

The DSP 21 may comprise any suitable commercially available DSP or processor. 
Preferably, the data storage controller 20 utilizes a DSP from Texas Instruments' 320 
series, C62x family, of DSPs (such as TMS320C621 1GFN-150), although any other DSP 

10 or processor comprising a similar architecture and providing similar functionalities may 
be employed. The preferred DSP is capable of up to 1 .2 billion instructions per second. 
Additional features of the preferred DSP include a highly parallel eight processor single 
cycle instruction execution, onboard 4K byte LIP Program Cache, 4K LID Data Cache, 
and 64K byte Unified L2 Program/Data Cache. The preferred DSP further comprises a 

15 32 bit External Memory Interface (EMIF) that provides for a glueless interface to the 
RAM 23 and the non-volatile memory 24 (ROM). The DSP further comprises two 
multi-channel buffered serial ports (McBSPs) and two 32 bit general purpose timers. 
Preferably, the storage controller disables the I/O capability of these devices and utilizes 
the I/O ports of the DSP as general purpose I/O for both programming the programmable 

2 0 logic device 22 using a strobed eight bit interface and signaling via a Light Emitting 

Diode (LED). Ancillary DSP features include a 16 bit Host Port Interface and full JTAG 
emulation capability for development support. 

The programmable logic device 22 may comprise any form of volatile or non- 
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volatile memory. Preferably, the programmable logic device 22 comprises a dynamically 
reprogrammable FPGA (field programmable gate array) such as the commercially 
available Xilinx Spartan Series XCS40XL-PQ240-5 FPGA. As discussed in detail 
herein, the FPGA instantiates and drives the disk and bus interfaces 14, 15. 

5 The non-volatile memory device 24 preferably comprises a 128 Kbyte M27W101- 

80K one time (erasable) programmable read only memory, although other suitable non- 
volatile storage devices may be employed. The non-volatile memory device 24 is 
decoded at a designated memory space in the DSP 21 . The non- volatile memory device 
24 stores the logic for the DSP 21 and configuration data for the programmable logic 

1 0 device 22. More specifically, in a preferred embodiment, the lower 80 Kbytes of the non- 
volatile memory device 24 are utilized for storing DSP program code, wherein the first lk 
bytes are utilized for the DSP's boot loader. Upon reset of the DSP 21 (via boot 
configuration circuit 28), the first IK of memory of the non- volatile memory device 24 is 
copied into an internal RAM of the DSP 21 by e.g., the DSP's Enhanced DMA Controller 

1 5 (EDMA). Although the boot process begins when the CPU of the host system is released 
from external reset, the transfer of the boot code into the DSP and the DSP's initialization 
of the programmable logic device actually occurs while the CPU of the host system is 
held in reset. After completion of the IK block transfer, the DSP executes the boot loader 
code and continues thereafter with executing the remainder of the code in non-volatile 

2 0 memory device to program the programmable logic device 22. 

More specifically, in a preferred embodiment, the upper 48K bytes of the non- 
volatile memory device 24 are utilized for storing configuration data associated with the 
programmable logic device 22. If the data storage controller 20 is employed as the 
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primary boot storage device for the host computer, the logic for instantiating and driving 
the disk and bus interfaces 14, 15 should be stored on the data storage controller 20 
(although such code may be stored in remotely accessible memory locations) and loaded 
prior to release of the host system bus 16 from "reset". For instance, revision 2.2 of the 
PCI Local Bus specification calls for a typical delay of 100msec from power-stable before 
release of PCI Reset. In practice this delay is currently 200msec although this varies 
amongst computer manufacturers. A detailed discussion of the power-on sequencing and 
boot operation of the data storage controller 20 will be provided below. 

Fig. 3 illustrates another embodiment of a data storage controller 30 wherein the 
data storage controller 35 is embedded within the motherboard of the host computer 
system. This architecture provides the same functionality as the system of Fig. 2, and 
also adds the cost advantage of being embedded on the host motherboard. The system 
comprises additional RAM and ROM memory devices 23a, 24a, operatively connected to 
the DSP 21 via a local bus 25a. 

Fig. 4 illustrates another embodiment of a data storage controller. The data 
storage controller 40 comprises a PCB implementation that is capable of supporting 
RAID levels 0,1 and 5. This architecture is similar to those of Fig. 1 and 2, except that a 
plurality of programmable logic devices 22, 22a are utilized. The programmable logic 
device 22 is dedicated to controlling the bus interface 15. The programmable logic 
device 22a is dedicated to controlling a plurality of disk interfaces 14, preferably three 
interfaces. Each disk interface 14 can connect up to two drives. The DSP in conjunction 
with the programmable logic device 22a can operate at RAID level 0, 1 or 5. At RAID 
level 0, which is disk striping, two interfaces are required. This is also true for RAID 
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level 1, which is disk mirroring. At RAID level 5, all three interfaces are required. 

Fig. 5 illustrates another embodiment of a data storage controller according to the 
present invention. The data storage controller 45 provides the same functionality as that 
of Figure 4, and has the cost advantage of being embedded within the computer system 
5 motherboard. 

II. Initialising A Programmable Logic Device 

As discussed above with reference to Fig. 2, for example, the data storage 
controller 20 preferably employs an onboard Texas Instruments TMS320C621 1 Digital 
Signal Processor (DSP) to program the onboard Xilinx Spartan Series XCS40XL FPGA 

1 0 upon power-up or system level PCI reset. The onboard boot configuration circuit 28 
ensures that from system power-up and/or the assertion of a bus reset (e.g., PCI reset), 
the DSP 21 is allotted a predetermined amount of time (preferably a minimum of 10msec) 
to boot the DSP 21 and load the programmable logic device 22. Because of a potential 
race condition between either the host computer power-up or assertion of PCI Bus reset 

1 5 and configuration of the programmable logic device 20 (which is used for controlling the 
boot device and accepting PCI Commands), an "Express Mode" programming mode for 
configuring the SpartanXL family XCS40XL device is preferably employed. The 
XCS40XL is factory set to byte-wide Express-Mode programming by setting both the 
Ml /MO bits of the XCS40XL to 0x0. Further, to accommodate express mode 

2 0 programming of the programmable logic device 22, the DSP 21 is programmed to utilize 
its serial ports reconfigured as general purpose I/O. However, after the logic device 22 is 
programmed, the DSP 21 may then reconfigure its serial ports for use with other devices. 
Advantageously, using the same DSP ports for multiple purposes affords greater 
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flexibility while minimizing hardware resources and thus reducing product cost. 

The volatile nature of the logic device 22 effectively affords the ability to have an 
unlimited number of hardware interfaces. Any number of programs for execution by the 
programmable logic device 22 can be kept in an accessible memory location (EPROM, 
5 hard disk, or other storage device). Each program can contain new disk interfaces, 
interface modes or subsets thereof. When necessary, the DSP 21 can clear the interface 
currently residing in the logic device 22 and reprogram it with a new interface. This 
feature allows the data storage controller 20 to have compatibility with a large number of 
interfaces while minimizing hardware resources and thus reducing product cost. 

10 A preferred protocol for programming the programmable logic device can be 

summarized in the following steps: (1) Clearing the configuration memory; (2) 
Initialization; (3) Configuration; and (4) Start-Up. When either of three events occur: the 
host computer is first powered-up or a power failure and subsequent recovery occurs 
(cold boot), or a front panel computer reset is initiated (warm boot), the host computer 

1 5 asserts RST# (reset) on the PCI Bus. As noted above, the data storage controller 20 
preferably comprises a boot configuration circuit 28 that senses initial host computer 
power turn-on and/or assertion of a PCI Bus Reset ("PCI RST#"). It is important to note 
that assuming the data storage controller 20 is utilized in the computer boot-up sequence, 
it should be available exactly 5 clock cycles after the PCI RST# is deasserted, as per PCI 

2 0 Bus Specification Revision 2.2. While exact timings vary from computer to computer, the 
typical PCI bus reset is asserted for approximately 200msec from initial power turn-on. 

In general, PCI RST# is asserted as soon as the computer's power exceeds a 
nominal threshold of about 1 volt (although this varies) and remains asserted for 200msec 
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thereafter. Power failure detection of the 5 volt or 3.3 volt bus typically resets the entire 
computer as if it is an initial power-up event (i.e., cold boot). Front panel resets (warm 
boots) are more troublesome and are derived from a debounced push-button switch input. 
Typical front panel reset times are a minimum of 20msec, although again the only 
5 governing specification limit is 1msec reset pulse width. 

As discussed in detail below, it may not be necessary to reload the programmable 
logic device 22 each time the DSP is reset. The boot configuration circuit 20 preferably 
comprises a state machine output signal that is readable by the DSP 21 to ascertain the 
type of boot process requested. For example, with a front-panel reset (warm boot), the 
1 0 power remains stable on the PCI Bus, thus the programmable logic device 22 should not 
require reloading. 

Referring now to Fig. 6, a flow diagram illustrates a method for initializing the 
programmable logic device 22 according to one aspect of the invention. In the following 
discussion, it is assumed that the programmable logic device 22 is always reloaded, 

1 5 regardless of the type of boot process. Initially, in Fig. 6a, the DSP 21 is reset by 

asserting a DSP reset signal (step 50). Preferably, the DSP reset signal is generated by 
the boot circuit configuration circuit 28 (as described in the above-incorporated U.S. 

Serial No. (Attorney Docket No. 801 1-10). While the DSP reset signal is 

asserted (e.g., active low), the DSP is held in reset and is initialized to a prescribed state. 

2 0 Upon deassertion of the DSP Reset signal, the logic code for the DSP (referred to as the 
"boot loader") is copied from the non- volatile logic device 24 into memory residing in the 
DSP 21 (step 51). This allows the DSP to execute the initialization of the programmable 
logic device 22. In a preferred embodiment, the lower IK bytes of EPROM memory is 
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copied to the first lk bytes of DSP's low memory (0x0000 0000 through 0x0000 03FF). 
As noted above, the memory mapping of the DSP 21 maps the CE1 memory space 
located at 0x9000 0000 through 0x9001 FFFF with the OTP EPROM. In a preferred 
embodiment using the Texas Instrument DSP TMS320c621 1GFN-150, this ROM boot 
5 process is executed by the EDMA controller of the DSP. It is to be understood, however, 
that the EDMA controller may be instantiated in the programmable logic device (Xilinx), 
or shared between the DSP and programmable logic device. 

After the logic is loaded in the DSP 21, the DSP 21 begins execution out of the 
lower IK bytes of memory (step 52). In a preferred embodiment, the DSP 21 initializes 

1 0 with at least the functionality to read EPROM Memory (CE1) space. Then, as described 
above, the DSP preferably configures its serial ports as general purpose I/O (step 53). 

Next, the DSP 21 will initialize the programmable logic device 22 using one or more 
suitable control signals, (step 54). After initialization, the DSP 21 begins reading the 
configuration data of the programmable logic device 22 from the non-volatile memory 24 

1 5 (step 55). This process begins with clearing a Data Byte Counter and then reading the 

first data byte beginning at a prespecified memory location in the non-volatile memory 24 
(step 56). Then, the first output byte is loaded into the DSP's I/O locations with LSB at 
DO and MSB at D7 (step 57). Before the first byte is loaded to the logic device 22, a 
prespecified time delay (e.g., 5usec) is provided to ensure that the logic device 22 has 

2 0 been initialized (step 58). In particular, this time delay should be of a duration at least 
equal to the internal setup time of the programmable logic device 22 from completion of 
initialization. Once this time delay has expired, the first data byte in the I/O bus 26 of the 
DSP 21 is latched into the programmable logic device 22 (step 59). 
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Next, a determination is made as to whether the Data Byte Counter is less than a 
prespecified value (step 60). If the Data Byte Counter is less than the prespecified value 
(affirmative determination in step 60), the next successive data byte for the programmable 
logic device 22 is read from the non-volatile memory 24 (step 61) and the Data Byte 
5 Counter is incremented (step 62). 

Next, the read data byte is loaded into the I/O of the DSP (step 63). A time delay 
of, e.g., 20 nsec is allowed to expire before the data byte is latched to the programmable 
logic device to ensure that a minimum data set-up time to the programmable logic device 
21 is observed (step 64) and the process is repeated (return to step 60). It is to be 
1 0 appreciated that steps 60-64 may be performed while the current data byte is being 

latched to the programmable logic device. This provides "pipeline" programming of the 
logic device 22 and minimizes programming duration. 

When the Data Byte Counter is not less than the prespecified count value 
negative determination in step 60), as shown in Fig. 6b, the last data byte is read from the 
1 5 non-volatile memory and latched to the programmable logic device 22, and the DSP 2 1 
will then poll a control signal generated by the programmable logic device 22 to ensure 
that the programming of the logic device 22 is successful (step 65). If programming is 
complete (affirmative determination in step 66), the process continues with the remainder 
of the data storage controller initialization (step 67). Otherwise, a timeout occurs (step 
2 0 68) and upon expiration of the timeout, an error signal is provided and the programming 
process is repeated (step 69).. 
III. Data Storage and Retrieval Protor ols 

A detailed discussion of operational modes of a data storage controller will now 
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be provided with reference to the embodiment of Fig 2 (although it is to be understood 
that the following discussion is applicable to all the above-described embodiments). The 
data storage controller 20 utilizes a plurality of commands to implement the data storage, 
retrieval, and disk maintenance functions described herein. Each command preferably 
comprises eight thirty-two bit data words stored and transmitted in little endian format. 
The commands include: Read Disk Data; Write Disk Data; and Copy Disk Data, for 
example. For example, a preferred format for the "Read Disk Data" command is: 



31 



16 15 



8 7 



0 



Command Packet Number 
OOOOh to FFFFh 



Command Type 
OOh 



Command Parameters 



OOh 

04h 
08h 
OCh 
lOh 
14h 
18h 
ICh 



Starting Block Address (Least Significant Word) 



Starting Block Address (Most Significant Word) 



Number of Blocks (Least Significant Word) 



Number of Blocks (Most Significant Word) 



Destination Address (Least Significant Word) 



Destination Address (Most Significant Word) 



Checksum 



Reserved 



The host computer commands the data storage controller 20 over the PCI Bus 16, 
for example. Upon computer power-up or reset, the host computer issues a PCI Bus 
Reset with a minimum pulse width of 100msec (in accordance with PCI Bus 
Specification Revision 2.2). Upon completion of the PCI Bus reset, the data storage 
controller 20 is folly initialized and waiting for completion of the PCI configuration 
cycle. Upon completion of the PCI configuration cycles, the data storage controller will 
wait in an idle state for the first disk command. 
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During operation, the host operating system may issue a command to the data 
storage controller 20 to store, retrieve, or copy specific logical data blocks. Each 
command is transmitted over the PCI Bus 16 at the Address assigned to the Base Address 
Register (BAR) of the data storage controller 20. 
5 The commands issued by the host system to the data storage controller and the 

data transmitted to and from the data storage controller are preferably communicated via 
a 32 bit, 33MHz, PCI Data Bus. As noted above, the PCI Interface is preferably housed 
within the onboard Xilinx Spartan XCS40XL-5 40,000 field programmable gate array 
which instantiates a PCI 32, 32 Bit, 33MHz PCI Bus Interface (as per PCI Bus Revision 
10 2.2). 

The PCI Bus interface operates in Slave Mode when receiving commands and as a 
Bus Master when reading or writing data. The source and destination for all data is 
specified within each command packet. When setting up data transfers, the Enhanced 
Direct Memory Access (EDMA) Controller of the DSP (or the Xilinx) utilizes two 

1 5 Control Registers, a 1 6 Word Data Write to PCI Bus FIFO, a 1 6 Word Data Read From 
PCI Bus FIFO, and a PCI Data Interrupt (PCIDATINT). The 32 Bit PCI Address 
Register holds either the starting Source Address for data storage controller Disk Writes 
where data is read from the PCI Bus, or the starting Destination Address for data storage 
controller Disk Reads where data is written to the PCI Bus. The second control register is 

20 a PCI Count Register that specifies the direction of the data transfer along with the 
number of 32 bit Data words to be written to or from the PCI bus. 

Data is written to the PCI Bus from the DSP via a 16 Word PCI Data Write FIFO 
located within a prespecified address range. Data writes from the DSP to anywhere 
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within the address range place that data word in the next available location within the 
FIFO. Data is read from the PCI Bus to the DSP via a 16 Word PCI Data Read FIFO 
located within a prespecified address range and data read by the DSP from anywhere 
within this address range provides the next data word from the FIFO. 
5 After completion of the Xilinx initialization by the DSP and subsequent negation 

of the PCI Bus Reset signal (RST#) by the host computer's PCI Bridge, the data storage 
controller is ready to accept commands from the host computer via the PCI Bus. When 
accepting commands it should be noted that the data storage controller is a PCI Target 
(Slave) Device. Commands are preferably fixed in length at exactly 8 (thirty-two bit) 
1 0 words long. Commands are written from the host computer to the data storage controller 
via the PCI Bus utilizing the data storage controller's Base Address Register 0 (BARO). 
The PCI Bus Reset initially sets the Command FIFO's Counter to zero and also signals 
the Xilinx's PCI Bus State Controller that the Command FIFO is empty and enable to 
accept a command. 

1 5 Whenever a data write occurs within the valid data range of BARO, the data word 

is accepted from PCI Bus and placed in the next available memory position within the 
Command FIFO. When the last of the 8 thirty-two bit data words is accepted by the PCI 
Bus (thus completing the command, i.e. last word for the command FIFO to be full), the 
PCI Bus State Controller is automatically set to Target Abort (within same PCI 

2 0 Transaction) or Disconnect Without Data for all subsequent PCI transactions that try to 
writes to BARO. This automatic setting is the responsibility of the Xilinx PCI Data 
Interface. 

The PCI Command FIFO State Controller then asserts the Command Available 
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Interrupt to the DSP. The DSP services the Command Available Interrupt by reading the 
command data from a prespecified address range. It should be noted that the command 
FIFO is read sequentially from any data access that reads data within such address range. 
It is the responsibility of the DSP to understand that the data is read sequentially from any 
5 order of accesses within the data range and should thus be stored accordingly. 

Upon completion of the Command Available Interrupt Service Routine the DSP 
executes a memory read or write to desired location within the PCI Control Register 
Space mapped into the DSP's CE3 (Xilinx) memory space. This resets the Command 
FIFO Counter back to zero. Next, the DSP executes a memory read or write to location 

10 in the DSP Memory Space that clears the Command Available Interrupt. Nested 

interrupts are not possible since the PCI Bus State Machine is not yet able to accept any 
Command Data at BARO. Once the Command Available Interrupt routine has cleared the 
interrupt and exited, the DSP may then enable the PCI State Machine to accept a new 
command by reading or writing to PCI Command Enable location within the PCI 

1 5 Command FIFO Control Register Space. 

A preferred architecture has been selected to enable the data storage controller to 
operate on one command at a time or to accept multiple prioritized commands in future 
implementations. Specifically, the decoupling of the Command Available Interrupt 
Service Routine from the PCI State Machine that accepts Commands at BARO enables 

2 0 the DSP's "operating system kernel" to accept additional commands at any time by 

software command. In single command operation, a command is accepted, the Command 
Available Interrupt Cleared, and the Command executed by the data storage controller in 
PCI Master Mode prior to the enabling of the PCI State machine to accept new 
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commands. 

In a prioritized multi-command implementation, the "operating system kernel" 
may elect to immediately accept new commands or defer the acceptance of new 
commands based upon any software implemented decision criteria. In one embodiment, 
the O/S code might only allow a pre-specified number of commands to be queued. In 
another embodiment, commands might only be accepted during processor idle time or 
when the DSP is not executing time critical (i.e. highly pipelined) compress/decompress 
routines. In yet another embodiment, various processes are enabled based upon a pre- 
emptive prioritized based scheduling system. 

As previously stated, the data storage controller retrieves commands from the 
input command FIFO in 8 thirty-two bit word packets. Prior to command interpretation 
and execution, a command's checksum value is computed to verify .the integrity of the 
data command and associated parameters. If the checksum fails, the host computer is 
notified of the command packet that failed utilizing the Command Protocol Error 
Handler. Once the checksum is verified the command type and associated parameters are 
utilized as an offset into the command "pointer" table or nay other suitable command/data 
structure that transfers control to the appropriate command execution routine. 

Commands are executed by the data storage controller with the data storage 
controller acting as a PCI Master. This is in direct contrast to command acceptance 
where the data storage controller acts as a PCI Slave. When acting as a PCI Bus Master, 
the data storage controller reads or writes data to the PCI Bus utilizing a separate PCI Bus 
Data FIFO (distinct & apart from the Command FIFO). The PCI Data FIFO is 64 (thirty- 
two bit) words deep and may be utilized for either data reads or data writes from the DSP 
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to the PCI Bus, but not both simultaneously. 

For data to be written from the data storage controller to the Host Computer, the 
DSP must first write the output data to the PCI Bus Data FIFO. The Data FIFO is 
commanded to PCI Bus Data Write Mode by writing to a desired location within the 
Xilinx (CE3) PCI Control Register Space. Upon PCI Bus Reset the default state for the 
PCI Data FIFO is write mode and the PCI Data FIFO Available Interrupt is cleared. The 
PCI Data FIFO Available Interrupt should also be software cleared by writing to a 
prespecified location. Preferably, the first task for the data storage controller is for 
system boot-up or application code to be downloaded from disk. For reference, PCI Data 
Read Mode is commanded by writing to location BFFO 0104. The PCI Bus Reset 
initializes the Data FIFO Pointer to the first data of the 64 data words within the FIFO. 
However this pointer should always be explicitly initialized by a memory write to 
location BFFO 0108. This ensures that the first data word written to the FIFO by the DSP 
performing the data write anywhere in address range B000 0000 to B000 01FF is placed 
at the beginning of the FIFO. Each subsequent write to any location within this address 
range then places one thirty-two bit data word into the next available location within the 
PCI Data FIFO. The FIFO accepts up to 64 thirty-two bit data words although it should 
be clearly understood that not all data transfers to and from the PCI Bus will consist of a 
full FIFO. Counting the number of thirty-two bit data words written to the PCI Data 
FIFO is the responsibility of the DSP Code. It is envisioned that the DSP will, in general, 
use 64 word DMA data transfers, thus alleviating any additional processor overhead. 

When the data has been transferred from the DSP to the PCI Data FIFO, the PCI 
Bus Controller also needs the address of the PCI Target along with the number of data 
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words to be transmitted. In the current data storage controller implementation, the PCI 
Bus Address is thirty-two bits wide, although future PCI bus implementations may utilize 
multiword addressing and/or significantly larger (64 bit & up) address widths. The single 
thirty-two bit address word is written by the DSP to memory location aaaa+OxlO in the 
PCI Control Register Space. 

Finally, the PCI Bus Data Write transaction is initiated by writing the PCI Data 
FIFO word count to a prespecirled memory address. The word count value is always 
decimal 64 or less (0x3F). When the count register is written the value is automatically 
transferred to the PCI Controller for executing the PCI Bus Master writes. 

When the PCI Bus has completed the transfer of all data words within the PCI 
Data FIFO the PCI Data FIFO Available Interrupt is set. The DSP PCI Data FIFO 
Available Interrupt handler will then check to see if additional data is waiting or expected 
to be written to the PCI Data Bus. If additional data is required the interrupt is cleared 
and the data transfer process repeats. If no additional data is required to be transferred 
then the interrupt is cleared and the routine must exit to a system state controller. For 
example, if the command is complete then master mode must be disabled and then slave 
mode (command mode) enabled - assuming a single command by command execution 
data storage controller. 

For data to be read by the data storage controller from the Host Computer, the 
DSP must command the PCI Bus with the address and quantity of data to be received. 

The PCI Data FIFO is commanded to PCI Bus Data Read Mode by writing to a 
desired location within the Xilinx (CE3) PCI Control Register Space. Upon PCI Bus 
Reset the default state for the PCI Data FIFO is Write Mode and the PCI Data FIFO Full 
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Interrupt is cleared. The PCI Data FIFO Full Interrupt should also be cleared via software 
by writing to such location. The PCI Bus Reset also initializes the PCI Data FIFO Pointer 
to the first data word of the available 64 data words within the FIFO. However this 
pointer should always be explicitly initialized by a memory write to prespecified location. 
5 For data to be read from the PCI Bus by the data storage controller, the Xilinx PCI 

Bus Controller requires the address of the PCI Target along with the number of data 
words to be received. In the current data storage controller implementation, the PCI Bus 
Address is thirty-two bits wide, although future PCI bus implementations may utilize 
multiword addressing and/or significantly larger (64 bit & up) address widths. The single 

1 0 thirty-two bit address word is written by the DSP to prespecified memory location in the 
PCI Control Register Space. 

Finally, the PCI Bus Data Read transaction is initiated by writing the PCI Data 
FIFO word count to prespecified memory address. The word count value is always 
decimal 64 or less (0x3F). When the count register is written the value is automatically 

1 5 transferred to the PCI Controller for executing the PCI Bus Master Read. 

When the PCI Bus has received all the requested data words PCI Data FIFO Full 
Interrupt is set. The DSP PCI Data FIFO Full Interrupt handler will then check to see if 
additional data is waiting or expected to be read from the PCI Data Bus. If additional 
data is required the interrupt is cleared and the data receipt process repeats. If no 

2 0 additional data is required to be transferred, then the interrupt is cleared and the routine 
exits to a system state controller. For example, if the command is complete then master 
mode must be disabled and then slave mode (command mode) enabled - assuming a 
single command by command execution data storage controller. 
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It is clearly understood that there are other techniques for handling the PCI Data 
transfers. The current methodology has been selected to minimize the complexity and 
resource utilization of the Xilinx Gate Array. It should also be understood that the 
utilization of asynchronous memory reads and writes to initialize system states and 
5 synchronize events at a software level aids in both hardware and system level debug at the 
expense of increase software overhead. Subsequent embodiments of the gate array may 
automate resource intensive tasks if system level performance mandates. 
IV. Memory Bandwidth Allocation 

The onboard cache of the data storage controller is shared by the DSP, Disk 
1 0 Interface, and PCI Bus. The best case, maximum bandwidth for the SDRAM memory is 
70 megawords per second, or equivalently, 280 megabytes per second. The 32 bit PCI 
Bus interface has a best case bandwidth of 132 megabytes per second, or equivalently 33 
megawords per second. In current practice, this bandwidth is only achieved in short 
bursts. The granularity of PCI data bursts to/from the data storage controller is governed 
15 by the PCI Bus interface data buffer depth of sixteen words (64 bytes). The time division 
multiplexing nature of the current PCI Data Transfer Buffering methodology cuts the 
sustained PCI bandwidth down to 66 megabytes/second. 

Data is transferred across the ultraDMA disk interface at a maximum burst rate of 
66 megabytes/second. It should be noted that the burst rate is only achieved with disks 
2 0 that contain onboard cache memory. Currently this is becoming more and more popular 
within the industry. However assuming a disk cache miss, the maximum transfer rates 
from current disk drives is approximately six megabytes per second. Allotting for 
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technology improvements over time, the data storage controller has been designed for a 
maximum sustained disk data rate of 20 megabytes second (5 megawords/second). A 
design challenge is created by the need for continuous access to the SDRAM memory. 
Disks are physical devices and it is necessary to continuously read data from disk and 
5 place it into memory, otherwise the disk will incur a full rotational latency prior to 
continuing the read transaction. The maximum SDRAM access latency that can be 
incurred is the depth of the each of the two disk FIFO s or sixteen data. Assuming the 
FIFO is sixteen words deep the maximum latency time for emptying the other disk FIFO 
and restoring it to the disk interface is sixteen words at 5 megawords per second or (16 x 
1 0 3.2usec) = lusec. Each EMIF clock cycle is 14.2857nsec, thus the maximum latency 
translates to 224 clock cycles. It should be noted that transfers across the disk interface 
are 16 bits wide, thus the FPGA is required to translate 32 bit memory transfers to 16 bit 
disk transfers, and vice-versa. 

The DSP services request for its external bus from two requestors, the Enhanced 
1 5 Direct Memory Access (EDMA) Controller and an external shared memory device 

controller. The DSP can typically utilize the full 280 megabytes of bus bandwidth on an 
8k through 64K byte (2k word through 1 6k word) burst basis. It should be noted that the 
DSRA does not utilize the SDRAM memory for interim processing storage, and as such 
only utilizes bandwidth in direct proportion to disk read and write commands. 

2 0 For a single read from disk transaction data is transferred from and DMA transfer 

into SDRAM memory. This data is then DMA transferred by the DSP into onboard DSP 
memory, processed, and re transferred back to SDRAM in decompressed format (3 words 
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for every one word in). Finally the data is read from SDRAM by the PCI Bus Controller 
and placed into host computer memory. This equates to eight SDRAM accesses, one 
write from disk, one read by the DSP, three writes by the DSP and three by the PCI Bus. 
Disk write transactions similarly require eight SDRAM accesses, three from the PCI, 
5 three DSP reads, one DSP write, and one to the disk. 

Neglecting overhead for setting up DMA transfers, arbitration latencies, and 
memory wait states for setting up SDRAM transactions, the maximum DSRA theoretical 
SDRAM bandwidth limit for disk reads or writes is 280/8 megabytes second or 35 
megabytes second. It should be noted that the best case allocation of SDRAM bandwidth 
1 0 would be dynamic dependent upon the data compression and decompression ratios. 

Future enhancements to the data storage controller will utilize a programmable timeslice 
system to allocate SDRAM bandwidth, however this first embodiment will utilize a fixed 
allocation ratio as follows: 



If all three requestors require SDRAM simultaneously: 



15 



PCI Bus Interface 



3/8 



DSP Accesses 



4/8 



UltraDMA Disk Interface 



1/8 



If only the PCI Bus and DSP require SDRAM: 



PCI Bus Interface 



4/8 



20 



DSP Accesses 



4/8 



If only the DSP and Disk require SDRAM: 



DSP Accesses 



6/8 
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UltraDMA Disk Interface 2/8 
If only the PCI Bus and Disk require SDRAM: 



PCI Bus Interface 



6/8 



UltraDMA Disk Interface 



2/8 



5 



If only one device requires SDRAM it receives the full SDRAM bandwidth. It should be 
noted that different ratios may be applied based upon the anticipated or actual 
compression and/or decompression ratios. For example in the case of all three requestors 
active the following equation applies. Assume that data storage accelerator achieves a 
1 0 compression ratio A:B for example 3:1. The Numerator and denominators of the various 
allocations are defined as follows: 



UltraDMA Disk Interface B/K 
1 5 Where Further define a sum K equal to the sum of the numerators of the PCI Bus 

interface fraction, the DSP Access fraction, and the UltraDMA Disk Interfaces, i.e. K = 
2(A+B). Similarly: 

If only the PCI Bus and DSP require SDRAM: 



PCI Bus Interface 



A/K 



DSP Accesses 



(A+B)/K 



PCI Bus Interface 



(A+B)/K 



20 



DSP Accesses 



(A+B)/K 



If only the DSP and Disk require SDRAM: 
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DSP Accesses 



2A/K 



UltraDMA Disk Interface 



2B/K 



If only the PCI Bus and Disk require SDRAM: 



PCI Bus Interface 



2A/K 



UltraDMA Disk Interface 



2B/K 



It should be noted that the resultant ratios may all be scaled by a constant in order to most 
effectively utilize the bandwidths of the internal busses and external interfaces. In 
addition each ratio can be scale by an adjustment factor based upon the time required to 
complete individual cycles. For example if PCI Bus interface takes 20% longer than all 
other cycles, the PCI time slice should be adjusted longer accordingly. 

V. Tnstant Boot Device For Operating System. Application Program an H T.n^ing 

Typically, with conventional boot device controllers, after reset, the boot device 
controller will wait for a command over the computer bus (such as PCI). Since the boot 
device controller will typically be reset prior to bus reset and before the computer bus 
starts sending commands, this wait period is unproductive time. The initial bus 
commands inevitably instruct the boot device controller to retrieve data from the boot 
device (such as a disk) for the operating system. Since most boot devices are relatively 
slow compared to the speed of most computer busses, a long delay is seen by the 
computer user. This is evident in the time it takes for a typical computer to boot. 

It is to be appreciated that a data storage controller (having an architecture as 
described herein) may employ a technique of data preloading to decrease the computer 
system boot time. Upon host system power-up or reset, the data storage controller will 
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perform a self-diagnostic and program the programmable logic device (as discussed 
above) prior to completion of the host system reset (e.g., PCI bus reset) so that the logic 
device can accept PCI Bus commands after system reset. Further, prior to host system 
reset, the data storage controller can proceed to pre-load the portions of the computer 
5 operating system from the boot device (e.g., hard disk) into the on-board cache memory. 
The data storage controller preloads the needed sectors of data in the order in which they 
will be needed. Since the same portions of the operating system must be loaded upon 
each boot process, it is advantageous for the boot device controller to preload such 
portions and not wait until it is commanded to load the operating system. Preferably, the 

1 0 data storage controller employs a dedicated 10 channel of the DSP (with or without data 
compression) to pre-load computer operating systems and applications. 

Once the data is preloaded, when the computer system bus issues its first read 
commands to the data storage controller seeking operating system data, the data will 
already be available in the cache memory of the data storage controller. The data storage 

1 5 controller will then be able to instantly start transmitting the data to the system bus. 

Before transmission to the bus, if the was stored in compressed format on the boot device, 
the data will be decompressed. The process of preloading required (compressed) portions 
of the operating system significantly reduces the computer boot process time. 

In addition to preloading operating system data, the data storage controller could 

2 0 also preload other data that the user would likely want to use at startup. An example of 
this would be a frequently used application such as a word processor and any number of 
document files. 

There are several techniques that may be employed in accordance with the present 
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invention that would allow the data storage controller to know what data to preload from 
the boot device. One technique utilizes a custom utility program that would allow the 
user to specify what applications/data should be preloaded. 

Another technique (illustrated by the flow diagram of Figs. 7a and 7b) that may be 
5 employed comprises an automatic process that requires no input from the user. With this 
technique, the data storage controller maintain a list comprising the data associated with 
the first series of data requests received by the data storage controller by the host system 
after a power-on / reset. In particular, referring to Fig. 7a, during the computer boot 
process, the data storage controller will receive requests for the boot data (step 70). In 

1 0 response, the data storage controller will retrieve the requested boot data from the boot 
device (e.g., hard disk) in the local cache memory (step 71). For each requested data 
block, the data storage controller will record the requested data block number in a list 
(step 72). The data storage controller will record the data block number of each data 
block requested by the host computer during the boot process (repeat steps 70-72). When 

1 5 the boot process is complete (affirmative determination in step 73), the data storage 
controller will store the data list on the boot device (or other storage device) (step 74). 

Then, upon each subsequent power-on / reset (affirmative result in step 75), the 
data storage controller would retrieve and read the stored list (step 76) and proceed to 
preload the boot data specified on the list (i.e., the data associated with the expected data 

2 0 requests) into the onboard cache memory (step 77). It is to be understood that the 
depending on the resources of the given system (e.g., memory, etc.), the preloading 
process may be completed prior to commencement of the boot process, or continued after 
the boot process begins (in which case booting and preloading are performed 
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simultaneously). 

When the boot process begins (step 78) (i.e., the storage controller is initialized 
and the system bus reset is deasserted), the data storage controller will receive requests 
for boot data (step 79). If the host computer issues a request for boot data that is pre- 
5 loaded in the local memory of the data storage controller (affirmative result in step 80), 
the request is immediately serviced using the preloaded boot data (step 81). If the host 
computer issues a request for boot data that is not preloaded in the local memory of the 
data storage controller (negative determination in step 80), the controller will retrieve the 
requested data from the boot device, store the data in the local memory, and then deliver 

1 0 the requested boot data to the computer bus (step 82). In addition, the data storage 
controller would update the boot data list by recording any changes in the actual data 
requests as compared to the expected data requests already stored in the list (step 83). 
Then, upon the next boot sequence, the boot device controller would pre-load that data 
into the local cache memory along with the other boot data previously on the list. 

1 5 Further, during the boot process, if no request is made by the host computer for a 

data block that was pre-loaded into the local memory of the data storage controller 
(affirmative result in step 84), then the boot data list will be updated by removing the 
non-requested data block from the list (step 85). Thereafter, upon the next boot sequence, 
the data storage controller will not pre-load that data into local memory. 

20 VI. Quick Launch for Operating System, Application Program, and T parting 

It is to be appreciated that the data storage controller (having an architecture as 
described herein) may employ a technique of data preloading to decrease the time to load 
application programs (referred to as "quick launch"). Conventionally, when a user 
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launches an application, the file system reads the first few blocks of the file off the disk, 
and then the portion of the loaded software will request via the file system what 
additional data it needs from the disk. For example, a user may open a spreadsheet 
program, and the program may be configured to always load a company spreadsheet each 
5 time the program is started. In addition, the company spreadsheet may require data from 
other spreadsheet files. 

In accordance with the present invention, the data storage controller may be 
configured to "remember" what data is typically loaded following the launch of the 
spreadsheet program, for example. The data storage controller may then proceed to 

1 0 preload the company spreadsheet and all the necessary data in the order is which such 
data is needed. Once this is accomplished, the data storage controller can service read 
commands using the preloaded data. Before transmission to the bus, if the preloaded 
data was stored in compressed format, the data will be decompressed. The process of 
preloading (compressed) program data significantly reduces the time for launching an 

1 5 application. 

Preferably, a custom utility program is employed that would allow the user to 
specify what applications should be made ready for quick launch. 

Figs. 8a and 8b comprise a flow diagram of a quick launch method according to 
one aspect of the present invention. With this technique, the data storage controller 
2 0 maintains a list comprising the data associated with launching an application. In 

particular, when an application is first launched, the data storage controller will receive 
requests for the application data (step 90). In response, the data storage controller will 
retrieve the requested application data from memory (e.g., hard disk) and store it in the 



8011-15 



44 



local cache memory (step 91). The data storage controller will record the data block 
number of each data block requested by the host computer during the launch process (step 
92). When the launch process is complete (affirmative determination in step 93), the data 
storage controller will store the data list in a designated memory location (step 94). 
5 Then, referring to Fig. 8b, upon each subsequent launch of the application 

(affirmative result in step 95), the data storage controller would retrieve and read the 
stored list (step 96) and then proceed to preload the application data specified on the list 
(i.e., the data associated with the expected data requests) into the onboard cache memory 
(step 97). During the application launch process, the data storage controller will receive 

1 0 requests for application data (step 98). If the host computer issues a request for 

application data that is pre-loaded in the local memory of the data storage controller 
(affirmative result in step 99), the request is immediately serviced using the preloaded 
data (step 100). If the host computer issues a request for application data that is not 
preloaded in the local memory of the data storage controller (negative result in step 99), 

1 5 the controller will retrieve the requested data from the hard disk memory, store the data in 
the local memory, and then deliver the requested application data to the computer bus 
(step 101). In addition, the data storage controller would update the application data list 
by recording any changes in the actual data requests as compared to the expected data 
requests already stored in the list (step 102). 

2 0 Further, during the launch process, if no request is made by the host computer for 

a data block that was pre-loaded into the local memory of the data storage controller 
(affirmative result in step 103), then the application data list will be updated by removing 
the non-requested data block from the list (step 104). Thereafter, upon the next launch 
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sequence for the given application, the data storage controller will not pre-load that data 
into local memory. 

It is to be understood that the quick boot and quick launch methods described 
above are preferably implemented by a storage controller according to the present 
invention and may or may not utilize data compression/decompression by the DSP. 
However, it is to be understood that the quick boot and quick launch methods may be 
implemented by a separate device, processor, or system, or implemented in software. 
VII. Content Independent Data Compression 

It is to be understood that any conventional compression/decompression system 
and method (which comply with the above mentioned constraints) may be employed in 
the data storage controller for providing accelerated data storage and retrieval in 
accordance with the present invention. Preferably, the present invention employs the data 
compression/decompression techniques disclosed in the above-incorporated U.S. Serial 
No. 09/210,491. 

Referring to FIG. 9, a detailed block diagram illustrates an exemplary data 
compression system 110 that may be employed herein. Details of this data compression 
system are provided in U.S. Serial No. 09/210,491. In this embodiment, the data 
compression system 110 accepts data blocks from an input data stream and stores the 
input data block in an input buffer or cache 115. It is to be understood that the system 
processes the input data stream in data blocks that may range in size from individual bits 
through complete files or collections of multiple files. Additionally, the input data block 
size may be fixed or variable. A counter 120 counts or otherwise enumerates the size of 
input data block in any convenient units including bits, bytes, words, and double words. 
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It should be noted that the input buffer 115 and counter 120 are not required elements of 
the present invention. The input data buffer 1 15 may be provided for buffering the input 
data stream in order to output an uncompressed data stream in the event that, as discussed 
in further detail below, every encoder fails to achieve a level of compression that exceeds 
5 an a priori specified minimum compression ratio threshold. 

Data compression is performed by an encoder module 125 which may comprise a 
set of encoders El, E2, E3 ... En. The encoder set El, E2, E3 ... En may include any 
number "n" (where n may =1) of those lossless encoding techniques currently well known 
within the art such as run length, Huffman, Lempel-Ziv Dictionary Compression, 

1 0 arithmetic coding, data compaction, and data null suppression. It is to be understood that 
the encoding techniques are selected based upon their ability to effectively encode 
different types of input data. It is to be appreciated that a full complement of encoders are 
preferably selected to provide a broad coverage of existing and future data types. 

The encoder module 125 successively receives as input each of the buffered input 

1 5 data blocks (or unbuffered input data blocks from the counter module 120). Data 

compression is performed by the encoder module 125 wherein each of the encoders El .... 
En processes a given input data block and outputs a corresponding set of encoded data 
blocks. It is to be appreciated that the system affords a user the option to enable/disable 
any one or more of the encoders El .... En prior to operation. As is understood by those 

2 0 skilled in the art, such feature allows the user to tailor the operation of the data 

compression system for specific applications. It is to be further appreciated that the 
encoding process may be performed either in parallel or sequentially. In particular, the 
encoders El through En of encoder module 125 may operate in parallel (i.e., 
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simultaneously processing a given input data block by utilizing task multiplexing on a 
single central processor, via dedicated hardware, by executing on a plurality of processor 
or dedicated hardware systems, or any combination thereof). In addition, encoders El 
through En may operate sequentially on a given unbuffered or buffered input data block. 
5 This process is intended to eliminate the complexity and additional processing overhead 
associated with multiplexing concurrent encoding techniques on a single central 
processor and/or dedicated hardware, set of central processors and/or dedicated hardware, 
or any achievable combination. It is to be further appreciated that encoders of the 
identical type may be applied in parallel to enhance encoding speed. For instance, 
1 0 encoder El may comprise two parallel Huffman encoders for parallel processing of an 
input data block. 

A buffer/counter module 130 is operatively connected to the encoder module 125 
for buffering and counting the size of each of the encoded data blocks output from 
encoder module 125. Specifically, the buffer/counter 130 comprises a plurality of 

1 5 buffer/counters BC1, BC2, BC3 ....BCn, each operatively associated with a corresponding 
one of the encoders EL.. En. A compression ratio module 135, operatively connected to 
the output buffer/counter 130, determines the compression ratio obtained for each of the 
enabled encoders El ...En by taking the ratio of the size of the input data block to the size 
of the output data block stored in the corresponding buffer/counters BC1 ... BCn. In 

2 0 addition, the compression ratio module 135 compares each compression ratio with an a 
^non-specified compression ratio threshold limit to determine if at least one of the 
encoded data blocks output from the enabled encoders El... En achieves a compression 
that exceeds an a /?r/orz-specified threshold. As is understood by those skilled in the art, 
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the threshold limit may be specified as any value inclusive of data expansion, no data 
compression or expansion, or any arbitrarily desired compression limit. A description 
module 138, operatively coupled to the compression ratio module 135, appends a 
corresponding compression type descriptor to each encoded data block which is selected 
5 for output so as to indicate the type of compression format of the encoded data block. A 
data compression type descriptor is defined as any recognizable data token or descriptor 
that indicates which data encoding technique has been applied to the data. It is to be 
understood that, since encoders of the identical type may be applied in parallel to enhance 
encoding speed (as discussed above), the data compression type descriptor identifies the 

1 0 corresponding encoding technique applied to the encoded data block, not necessarily the 
specific encoder. The encoded data block having the greatest compression ratio along 
with its corresponding data compression type descriptor is then output for subsequent 
data processing, storage, or transmittal. If there are no encoded data blocks having a 
compression ratio that exceeds the compression ratio threshold limit, then the original 

1 5 unencoded input data block is selected for output and a null data compression type 

descriptor is appended thereto. A null data compression type descriptor is defined as any 
recognizable data token or descriptor that indicates no data encoding has been applied to 
the input data block. Accordingly, the unencoded input data block with its corresponding 
null data compression type descriptor is then output for subsequent data processing, 

2 0 storage, or transmittal . 

Again, it is to be understood that the embodiment of the data compression engine 
of Fig. 9 is exemplary of a preferred compression system which may be implemented in 
the present invention, and that other compression systems and methods known to those 
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skilled in the art may be employed for providing accelerated data storage in accordance 
with the teachings herein. Indeed, in another embodiment of the compression system 
disclosed in the above-incorporated U.S. Serial No. 09/210,491, a timer is included to 
measure the time elapsed during the encoding process against an a ^non-specified time 
5 limit. When the time limit expires, only the data output from those encoders (in the 
encoder module 125) that have completed the present encoding cycle are compared to 
determine the encoded data with the highest compression ratio. The time limit ensures 
that the real-time or pseudo real-time nature of the data encoding is preserved. In 
addition, the results from each encoder in the encoder module 125 may be buffered to 

1 0 allow additional encoders to be sequentially applied to the output of the previous encoder, 
yielding a more optimal lossless data compression ratio. Such techniques are discussed in 
greater detail in the above-incorporated U.S. Serial No. 09/210,491. 

Referring now to FIG. 10, a detailed block diagram illustrates an exemplary 
decompression system that may be employed herein or accelerated data retrieval as 

1 5 disclosed in the above-incorporated U.S. Serial No. 09/210,491 . In this embodiment, the 
data compression engine 180 retrieves or otherwise accepts compressed data blocks from 
one or more data storage devices and inputs the data via a data storage interface. It is to 
be understood that the system processes the input data stream in data blocks that may 
range in size from individual bits through complete files or collections of multiple files. 

2 0 Additionally, the input data block size may be fixed or variable. 

The data decompression engine 180 comprises an input buffer 155 that receives as 
input an uncompressed or compressed data stream comprising one or more data blocks. 
The data blocks may range in size from individual bits through complete files or 
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collections of multiple files. Additionally, the data block size may be fixed or variable. 
The input data buffer 55 is preferably included (not required) to provide storage of input 
data for various hardware implementations. A descriptor extraction module 160 receives 
the buffered (or unbuffered) input data block and then parses, lexically, syntactically, or 
5 otherwise analyzes the input data block using methods known by those skilled in the art 
to extract the data compression type descriptor associated with the data block. The data 
compression type descriptor may possess values corresponding to null (no encoding 
applied), a single applied encoding technique, or multiple encoding techniques applied in 
a specific or random order (in accordance with the data compression system embodiments 

1 0 and methods discussed above). 

A decoder module 165 includes one or more decoders Dl...Dn for decoding the 
input data block using a decoder, set of decoders, or a sequential set of decoders 
corresponding to the extracted compression type descriptor. The decoders Dl ...Dn may 
include those lossless encoding techniques currently well known within the art, including: 

15 run length, Huffman, Lempel-Ziv Dictionary Compression, arithmetic coding, data 
compaction, and data null suppression. Decoding techniques are selected based upon 
their ability to effectively decode the various different types of encoded input data 
generated by the data compression systems described above or originating from any other 
desired source. 

2 0 As with the data compression systems discussed in U.S. Application Serial No. 

09/210,491, the decoder module 165 may include multiple decoders of the same type 
applied in parallel so as to reduce the data decoding time. An output data buffer or cache 
170 may be included for buffering the decoded data block output from the decoder 
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module 165. The output buffer 70 then provides data to the output data stream. It is to be 
appreciated by those skilled in the art that the data compression system 1 80 may also 
include an input data counter and output data counter operatively coupled to the input and 
output, respectively, of the decoder module 165. In this manner, the compressed and 
corresponding decompressed data block may be counted to ensure that sufficient 
decompression is obtained for the input data block. 

Again, it is to be understood that the embodiment of the data decompression 
system 180 of FIG. 10 is exemplary of a preferred decompression system and method 
which may be implemented in the present invention, and that other data decompression 
systems and methods known to those skilled in the art may be employed for providing 
accelerated data retrieval in accordance with the teachings herein. 

Although illustrative embodiments have been described herein with reference to 
the accompanying drawings, it is to be understood that the present invention is not limited 
to those precise embodiments, and that various other changes and modifications may be 
affected therein by one skilled in the art without departing from the scope or spirit of the 
invention. All such changes and modifications are intended to be included within the 
scope of the invention as defined by the appended claims. 
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